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ARRANGEMENTS AND METHODS FOR LATENCY-SENSITIVE 



HASHING FOR COLLABORATIVE WEB CACHING 

Field of the Invention 

The present invention generally relates to the caching of web objects on network 
5 proxy servers located between client machines and content servers. 

Background of the Invention 

In recent years, the growth of the Internet has exploded, especially with regard to 
the World Wide Web. As a consequence, user response times for accessing the Web have 
become increasingly unsatisfactory. 

10 One common conventional approach to improving Web performance is to deploy 

proxy cache servers between clients and content servers. With proxy caching, most client 
requests can be serviced by the proxy caches, reducing latency delays. Network traffic on 
the Internet can also be significantly reduced in this manner, thus greatly reducing network 
congestion. In fact, many commercial companies are providing hardware and software 

15 products and solutions for Web caching, such as IBM, Sun Microsystems, Inktomi, 

Network Appliance and Akamai. Some of them are using geographically distributed data 
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centers for collaborative web caching. Namely, many geographically distributed proxies 
are increasingly used to collaborate in web caching. 

To collaborate in web caching, a coordinating protocol is generally required. Hash 
routing is an emerging approach to coordinating a collection of collaborating proxy 

5 caches. Examples of hash routing include the "cache array routing protocol" (CARP) and 
"consistent hashing". In "Cache Array Routing Protocol, v 1 .0," (Internet Draft, 
httpV/wmjrra^^^ 1998, V. Valloppillil and K. W. Ross), 

the draft of CARP is described. In "Hash-Routing for Collections of Shared Web 
Caches," {IEEE Network Magazine, pp. 37-44, Nov.-Dec. 1997, K. W. Ross), the 

10 performance of CARP and other protocols is analyzed. In "Web Caching with Consistent 
Hashing," (Proc. Of 8th International World Wide Web Conference, pp. 125-135, 1999, 
D. Karger et al.), the application of consistent hashing to web caching is described: 

Basically, hashing partitions the entire URL space among the caches, creating a 
single logical cache. Each cache is responsible for requests belonging to the assigned 
15 partition. Requests are sent to the proper proxy caches based on the hash values of the 
corresponding URLs. The mapping between hash values and proxy cache IDs can be 
done either by the browsers or by the domain name servers (DNS). 
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More and more geographically distributed proxies are used in collaborative web 
caching. For example, commercial companies, such as Akamai and Inktomi, are using 
cache servers residing on geographically distributed data centers for web caching. As a 
result, response times tend to be negatively impacted for those requests hashed into 
5 geographically distant proxies or overloaded proxies. Distant proxies tend to incur longer 
network latency delays. Overloaded proxies can cause significant delays as well, no 
matter how close they are to the browsers. As a result, a user may experience 
unpredictably slow response times for certain URL requests that are hashed into far away 
or overloaded proxy caches. 

10 However, traditional hashing-based approach to collaborative web caching does 

not deal with network latency. It either avoids hashing into geographically distant proxy 
caches or hashes to all proxy caches regardless of network latency. For example, in "Web 
Caching with Consistent Hashing," (Proc. Of 8th International World Wide Web 
Conference, pp. 125-135, 1999), a user's geographical region is encoded into the hash 

15 value and sent by the browser to a DNS in its geographical region. The DNS then maps 
the encoded hash value to a proxy cache ID within the same region. Thus, requests are 
served only by proxies in a geographically close region. It works well if the proxy caches 
within a region can adequately service all the requests originated within the same region. 
However, if workloads are skewed among regions, proxies in one region may be 
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overloaded while those in another region are underloaded. As a result, the degree of 
collaboration among proxies is limited by geographical locations. 

On the other hand, one can simply hash requests into all collaborating proxy 
caches regardless of geographical locations. In this case, load tends to be more balanced 

5 among all the geographically distributed cooperating caches. However, it does not take 
into account network latency delays due to geographical distances. It does not deal with 
"hot spots", either. A "hot spot" may be defined as a website or web page that 
experiences tremendous demand over a very short period of time, or a brief "spike" in the 
number of users wishing to access the website or web page. In the presence of hot spots, 

10 all the references to the hot spots are hashed into the same proxies. As a result, the 
proxies that handle the hot spots can easily become overloaded. 

Therefore, a need has been recognized in connection with attending to the latency 
issue in hashing-based web caching. More specifically, a need has been recognized in 
connection with providing a latency-sensitive hashing for collaborative web caching 
15 among geographically distributed proxy caches. 
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Summary of the Invention 

In accordance with the at least one presently preferred embodiment of the present 
invention, the mentioned latency problems associated with the hashing-based approach to 
collaborative web caching are solved. Latency-sensitive hashing systems and methods are 
5 contemplated herein for collaborative web caching among geographically distributed 
proxy caches. 

In one embodiment of the present invention, URL requests are hashed into all 
proxies. However, it takes into account latency delays and potential overloaded proxies in 
choosing the target proxy for a request. In one embodiment of the present invention, a 
10 request is first hashed into an anchor hash partition. Each hash partition is mapped to one 
of the geographically distributed proxies. Secondly, a selection algorithm is used to pick a 
proxy among a small number of hash partitions adjacent to the anchor hash partition. The 
selection is based on an objective to reduce network latency and to avoid creating 
overloaded proxies. 

15 For a better understanding of the present invention, together with other and further 

features and advantages thereof, reference is made to the following description, taken in 
conjunction with the accompanying drawings, and the scope of the invention will be 
pointed out in the appended claims. 
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Brief Description of the Drawings 

Fig. 1 is a block diagram of a network system that supports web caching; 

Fig. 2 is a block diagram of a domain name server system that supports latency- 
sensitive hashing; 

5 Fig. 3 is a flow chart diagram of an operation by a domain name server that 

supports latency-sensitive hashing among a collection of proxy caches; 

Fig. 4 is a schematic illustration of a latency-sensitive hashing; 

Fig. 5 is a flow chart diagram of the candidate identification module of Fig. 2; 

Fig. 6 is a flow chart diagram of an indirect mapping of hash partitions to proxies 
10 whose locations can be viewed as geographically distributed clusters; 

Fig. 7 is a schematic illustration of the mapping of hash partitions to five proxy 
caches located within two geographical clusters; 

Fig. 8 is a flow chart diagram of the target selection module of Fig. 2; and 

Fig. 9 is a flow chart diagram of the determination of a whether a candidate proxy 
15 cache is overloaded (as briefly set forth in Fig. 8). 
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Description of the Preferred Embodiments 



Figure 1 is a block diagram of a network system that supports web caching among 
distributed proxy caches in accordance with an exemplary embodiment of the present 
invention. Proxy cache servers 105, 106 are deployed within the Internet 100 between 

5 client machines 101, 102 and content servers 107, 108. Domain name servers 103, 104 
are used also within the Internet 100 to map logical host names into physical IP addresses. 
Similar to content servers 107, 108, proxy caches 105, 106 are typically powerful server 
computer systems with tremendous storage space, including main memory and disks. 
For example, IBM's SP/2, RS/6000 servers and PC servers can be used as both proxy 

10 cache servers and content servers. On the other hand, client machines 101, 102 are 
typically PCs or workstations. 

Note that the terms "proxy cache server(s)", "proxy cache(s)", "proxy server(s)" 
and "proxy(ies)" are used interchangeably throughout the present disclosure. All of these 
terms are used to represent the computer systems that cache web objects in the Internet 
15 1 00 between client machines 1 0 1 , 1 02 and content servers 1 07, 1 08 . Proxy caches 105, 
106 can be geographically remote among them. Some of them can be in a local cluster. 
But, one cluster can be in a distant location from another cluster geographically. For 
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example, a cluster of proxy caches can be located in the San Jose, California, area while 
another cluster of proxy caches can be located in the New York City area. 

Users of the client machines 101, 102 access the information stored on the content 
servers 107, 108 through the Internet 100. With the employment of proxy caches 105, 
5 106, client requests are first sent to the proxy caches 105, 106, instead of the content 
servers 107, 108. If requested objects are found on the proxy caches 105, 106, the 
objects are returned to the client machines 101, 102 directly from the proxy caches 105, 
106. On the other hand, if requested objects are not found on the proxy caches 105, 106, 
requests are then forwarded to the content servers 107, 108. 

10 Typically, some type of browser software, such as the Netscape Navigator by 

Netscape Communications or the Internet Explorer by Microsoft Corp., will be running on 
the client machine 1 0 1 , 1 02. The user of a client machine typically specifies a URL, such 
as http://www.ibm.com, on the location field of a browser to go to a Web site. In 
hashing-based collaborative web caching, such a URL is used to compute a hash value, 

15 which in turn is mapped into one of the proxies. The hashing of a URL to a proxy cache 
server can be done by the browser software in the client machine. In this case, the logical 
host name of the proxy is typically used by the browser. This logical name needs to be 
mapped into a physical IP address by a domain name server in the network. Alternatively, 
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the browser software can simply compute a URL into a hash value and then send the hash 
value to a domain name server. The mapping of a hash value to the physical IP address of 
a proxy is then done by the domain name server. Once the EP address of the target proxy 
is identified, the request is sent to it. If the requested object can be found locally on the 
5 proxy cache, then it is returned directly from the proxy to the client machine. Otherwise, 
the request is forwarded by the proxy cache to the content server. 

It will be appreciated that the mapping of a hash value to a proxy cache among a 
collection of collaborative proxies is preferably done by a domain name server. This is 
because it is more efficient for the domain name servers to keep track of the changes in the 

10 collaborative proxy caches. Some of them may be removed from the network while others 
may be added. It is difficult to propagate such changes to each and every client machine 
in the Internet. Theoretically, however, the mapping can be performed by the browser 
software in a client machine. In such a case, it is generally done on the logical host name, 
not the physical BP address. The browser still sends the logical proxy name to a domain 

15 name server for the physical IP address. Thus, it is preferable that the latency-sensitive 
hashing be executed by a domain name server. The browser only computes the hash value 
and sends it to a domain name server for mapping it to the IP address of one of the 
collaborative proxy caches. 
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Figure 2 is a block diagram of a domain name server system that supports latency- 
sensitive hashing in accordance with an exemplary embodiment of the present invention. 
The domain name server system (103, 104 in Figure 1) is a computer system that includes 
CPU 200, disk 202 and dynamic random memory 201. The domain name server system is 
5 connected to the Internet. 

The domain name server logic related to latency-sensitive hashing 204 is an 
executable program logic stored on the disk 202. It can be loaded onto the memory 201 
to carry out the mapping of a hash value to the IP address of a proxy among a collection 
of collaborative proxy caches. 

10 The regular domain name server logic 203 is also an executable program logic 

stored on the disk 202 and can be loaded onto the memory 201 to carry out other domain 
name server function. 

The major functional modules of the latency-sensitive hashing logic 204 include a 
candidate identification module 205 (detailed in Figure 5), a target selection module 206 
15 (detailed description in Figure 8) and a local collection module 207. 

Figure 3 shows a flow chart diagram of a typical operation by a domain name 
server that supports latency- sensitive hashing among a collection of proxy caches. When 
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a request comes in, the system first checks if it is related to latency-sensitive hashing 301. 
If no, it performs regular domain name server function 303. If yes, it first identifies a set 
of candidate proxy caches 302. From this set of candidate proxy caches, it then selects a 
proxy cache after taking into consideration the latency delay as well as load condition 304. 

5 Figure 4 shows an example of a latency-sensitive hashing in accordance with an 

exemplary embodiment of the present invention. The hash value space is partitioned into a 
large number of hash partitions 402. Each URL hash value falls into one of the partitions. 
Each hash partition is mapped to a proxy ID 401. For instance, a, d, g, b, e, h, are the 
identifiers of proxies mapped to the hash partitions. As an example, it may be assumed 

10 that URL ul 406 and u2 407 are hashed into hash partitions corresponding to proxies a 
and h, respectively. Without considering latency, URL ul will be hashed into proxy a and 
URL u2 into proxy h, respectively. However, in considering latency, two additional 
nearby proxies are first identified in the hash value space as the candidate proxies. Then, 
the latency delay specified in 405 is examined to select a proxy with the smallest latency 

15 delay. As a result, proxy a is selected as the target proxy for URL ul and proxy c is 
selected as the target proxy for URL u2. 

Figure 5 shows, in accordance with a preferred embodiment of the present 
invention, a flow chart diagram of the candidate identification module 205 in Figure 2. 
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Candidate identification module 205 is responsible for identifying a set of candidate proxy 
caches for a given hash value computed from a URL. The hash value is preferably 
computed by the browser software in a client machine (101, 102 in Figure 1) since it can 
access the URL. In 501, the given hash value from a client machine is first mapped into 

5 an anchor hash partition. This can be easily done by partitioning the possible hash values 
into a predetermined number of partitions. The anchor partition can therefore be 
identified by checking the hash value against the boundaries of the hash partitions. Once 
the anchor hash partition is identified, in 502, a candidate set of hash partitions can be 
formed by including one or more nearby hash partitions to the anchor hash partition. The 

10 nearby hash partitions can be those with hash values greater than, or less than, or some 
greater than and some less than, that of the anchor hash partition. It will be appreciated 
that the hash partitions should be treated as a circular data structure. Namely, the 
partition with the largest hash values should wrap around and be next to the one with the 
smallest hash values. Finally, in 503, the set of candidate hash partitions are mapped into 

15 a set of candidate proxies. These candidate proxies will be examined by the target 

selection module (206 in Figure 2) to find a target proxy based on latency delays and load 
conditions. 

It will be appreciated that, if each hash partition has been initially assigned with the 
IP address of a proxy, it becomes quite easy to map the set of candidate hash partitions to 
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the set of candidate proxy caches in 303 . For example, a simple lookup will suffice. 
There are many different ways to assign hash partitions with proxy caches. One possible 
approach is simply by hashing each partition into an integer number between 1 and P, 
where P is the total number of proxy caches. Each number represents a proxy cache. If 

5 the total number of hash partitions is large enough, then these hash partitions will be more 
or less evenly distributed among all the proxy caches. Alternatively, one can first 
generate N/P random numbers between 0 and 1 for each proxy cache, where N is the total 
number of hash partitions and P is the total number of proxy caches. Each of the N/P 
random numbers is associated with the same corresponding proxy ID. Thus, there are N 

10 total random numbers generated, with N/P of them associated with one proxy ID. 

Secondly, these N random numbers are sorted into a list. Finally, one can assign each hash 
partition with the proxy ID associated with each random number in the sorted list. 

It will also be appreciated that, as more and more data centers are built in various 
parts of the globe for caching web objects, distributed collaborative proxy caches can be 
15 viewed as geographically distributed clusters. Within each cluster, there can be one or 
more cache servers. Furthermore, the number of proxy cache servers in each cluster can 
be quite different. As a result, a special mapping approach may be employed to ensure 
that the target selection module (206 in Figure 2) can easily find a proxy for a URL 
request within a close geographical region. 
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Fig. 6 shows a flow chart diagram of an indirect mapping of hash partitions to 
proxies whose locations can be viewed as geographically distributed clusters. Assume that 
there are M clusters. The number of proxy caches in a cluster is denoted as C } ,j = 1, 2, 
M. In 601, the indirect mapping first creates a proxy ID array with a two-level round- 

5 robin approach. Namely, it first chooses a cluster and then from within the chosen cluster 
it picks a proxy cache, all in a round-robin fashion, that is, for each cluster chosen, all 
proxy caches are chosen one at a time until they are exhausted. The total number of this 
proxy ID array isM * LCM C , where LCM C is the least common multiple of C p j = 1, 2, 
M. Secondly, in 602, a hash partition segment is created and each partition is assigned 

10 with an index of the proxy ID array created in 60 1 . P 3 represents the number of times a 
proxy ID appears in the proxy ID array. Each proxy ID is to be mapped to LCM P hash 
partitions in the hash partition segment, where LCM P is the least common multiple afPjJ 
= 1,2, M As a result, the size of the hash partition segment is LCM P * £ PjJ = I, 2, 
M Since there are P } appearances of proxy j in the proxy ID array and there are a 

15 total of LCMp hash partitions to be mapped with the indices of proxy j, each index will be 
assigned to LCMplPj hash partitions in the segment. After the construction of the hash 
partition segment, in 603, the hash partition segment is replicated for a number of times to 
construct the entire hash partitions. 
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To better understand the above the indirect mapping scheme, Fig. 7 shows an 
example of mapping hash partitions to 5 proxy caches located within two geographical 
clusters. One contains two proxy caches 701 and the other contains 3 proxy caches 702. 

5 Proxies a, b are in the first cluster while proxies c, d t e are in the second cluster. For 
constructing the proxy ID array, a total of 12 elements is needed since the least common 
multiple of 2 and 3 is 6. The proxy ID array 703 is then constructed by selecting a proxy 
from each cluster in a round-robin fashion. Also shown are the indices of the proxy ID 
array. The hash partition segment 704 is constructed by assigning the indices of the proxy 

10 ID array to the hash partitions. Since proxies a, b appear 3 times each in the proxy ID 
array and proxies c, d, e appear 2 times each, the size of the hash partition segment is 6 * 
5=30 (LCM P = 6 and £ Pj = 5). Moreover, there are 3 appearances of proxy a in the 
proxy ID array and its indices are 0, 4 and 8. Each index will be assigned to 2 hash 
partitions (6/3 = 2). Thus, the first 2 hash partitions are assigned with index 0, the next 2 

15 are assigned with index 4, and the next two are assigned with index 8. Similarly, proxy c 
appears 2 times in the proxy ID array with indices of 1 and 7. So, there are three hash 
partitions assigned with index 1 and another 3 partitions assigned with index 7. 
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It will also be appreciated that the indirect mapping scheme can be easily 
generalized to the case where each cluster contains proxy caches with unequal processing 
powers. Rj denotes the relative processing power of proxy caches in cluster/ The total 
size of the hash bucket segment becomes LCM P * S Pfa Using the above example in 
5 Figure 7, if proxy caches in the first cluster is twice as powerful as those in the second 
cluster, the size of the hash partition segment is 6*(2*2+3*l) - 42. As a result, there are 
4 hash partitions that will be assigned with index 0, 4 hash partitions with index 4, and 
another 4 with index 8. 

It will also be appreciated that with the indirect mapping, the candidate set should 
10 be chosen from the nearby proxies in the proxy ID array once the anchor proxy is 

identified. As such, any candidate set of size M will contain at least one proxy cache ID 
from each cluster, where M is the total number of clusters. As a result, the indirect 
mapping ensures that it is likely to find a geographically close proxy cache for any request. 

Figure 8 shows the flow chart diagram of the target selection module 206 (Figure 
15 2) in accordance with an exemplary embodiment of the present invention. The variable w 
denotes the size of the set of candidate proxy caches identified by the candidate 
identification module 205 (Figure 2). The target proxy cache is initially set to be the first 
proxy from the candidate set 801 . 
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The selection module loops through each candidate proxy cache until all w 
candidate proxies have been examined 802, It examines every candidate proxy cache to 
see if the latency delay can be improved if the request were to hash into it 804. If yes, the 
candidate proxy is further examined to see if it is currently overloaded 805. If no, then the 
5 candidate proxy becomes the new target 806. Otherwise, the selection module proceeds 
to examine the next candidate proxy cache from the rest of the candidate set 807. After 
all candidate proxies are examined, the final target proxy cache is returned 803. 

It will also be appreciated that the criteria for improvement in latency can be 
simply based on the minimum response time. It can also be based on a discounted 
10 response time that prefers the anchor proxy cache unless the response time is better by a 
predetermined amount. 

Figure 9 is a flow chart diagram of determining whether a candidate proxy cache is 
overloaded 805 (Figure 8) in accordance with an exemplary embodiment of the present 
invention. Assume that the load collection module 207 (Figure 2) periodically sends a 
15 probe message to each collaborating proxy cache for utilization conditions. Such proxy 
utilization conditions are maintained and the mean utilization and the utilization of the 
most utilized can be computed. Let Ujnax denote the utilization of the most utilized 
proxy cache server among the collaborating proxies and Ujnean denote the mean 
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utilization. Assume OVERLOAD is a predetermined constant, say 80%, that is deemed 
overloaded for a proxy cache server. If the utilization of a proxy cache server is at least 
as large as Ujnean and Ujnax is at least as large as OVERLOAD 901, then the proxy is 
considered to be overloaded 903. On the other hand, if Umax is less than OVERLOAD 

5 902, then a proxy is considered to be overloaded 903 only if its utilization is at least as 
large as (1+delta) *Ujnean, where delta is a constant, say 20%. The quantity delta is 
preferably used to provide an acceptable variance over the mean utilization Ujnean 
before overloading will be considered to occur. A typical, and eminently workable, value 
for delta would be 20%, although it is to be understood that essentially any number 

10 between zero and one is appropriate and acceptable for use as delta. 

If neither of the conditions in 901 and 902 are true, then the proxy is not 
considered to be overloaded 904. 

It will also be appreciated that the utilization of the most utilized proxy cache 
server can be an indication of load imbalance among all the proxy cache servers. If the 
15 overall system is highly unbalanced, i.e., Ujnax is large, then we want to be more 

conservative in allowing a new request to be hashed into a proxy cache. Thus, a proxy 
cache server is considered to be overloaded once its utilization reaches Ujnean. On the 
other hand, if the overall system is more balanced, i.e., Ujnax is small, then there is a 
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desire to be more "aggressive" in allowing a new request to be hashed into a proxy cache. 
As a result, a proxy cache server is not considered to be overloaded until its utilization is 
greater than Ujnean by at least a certain amount. Besides periodically collecting 
utilization conditions of all collaborating proxy caches, the load collection module 207 
5 (Figure 2) also maintains the latency delays between client machines 101, 102 (Figure 1) 
and the collaborating proxy caches 105, 106 (Figure 1). Such latency delays are 
dependent mostly on geographical distances, but they also depend on dynamic network 
traffic. The latency delays be periodically updated as well. 

It is to be understood that the present invention, in accordance with at least one 
10 presently preferred embodiment, includes an identifier for identifying a candidate set of 
proxy caches for a given URL based on information related to the URL and a selector for 
selecting a proxy cache from the candidate set at least on the basis of latency. The 
identifier and selector may be implemented together on a general-purpose computer 
running suitable software programs. These may also be implemented on an Integrated 
15 Circuit or part of an Integrated Circuit. Thus, it is to be understood that the invention 
may be implemented in hardware, software, or a combination of both. 
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If not otherwise stated herein , it is to be assumed that all patents, patent 
applications, patent publications and other publications mentioned and cited herein are 
hereby fully incorporated by reference herein as if set forth in their entirety herein. 

Although illustrative embodiments of the present invention have been described 
herein with reference to the accompanying drawings, it is to be understood that the 
invention is not limited to those precise embodiments, and that various other changes and 
modifications may be affected therein by one skilled in the art without departing from the 
scope or spirit of the invention. 
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Claims 

What is claimed is: 

L Method of selecting a proxy cache, said method comprising the steps of: 

identifying a candidate set of proxy caches for a given URL based on information 
5 related to said URL; and 

selecting a proxy cache from the candidate set at least on the basis of latency. 

2. The method according to Claim 1, wherein said selecting step comprises 
selecting a proxy cache from the candidate set at least on the basis of latency and load 
condition. 

10 3. The method according to Claim 1, wherein said identifying step comprises: 

hashing the URL into an anchor hash partition; 

forming a candidate set of hash partitions by including one or more nearby 
partitions into said anchor hash partition; and 

mapping each partition to a proxy cache. 
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4. The method according to Claim 1, wherein said identifying step comprises: 
creating an indirect mapping of hash partitions to a proxy ID array; 
hashing the URL into an anchor hash partition; 

finding the corresponding anchor proxy cache; and 

5 forming a candidate set of proxy caches by including one or more nearby proxy 

caches from the proxy ID array into the anchor proxy cache. 

5. The method according to Claim 1, wherein said selecting step comprises 
selecting a proxy cache from the candidate set of proxies based at least on minimum 
response time. 

10 6. The method according to Claim 1 3 wherein said selecting step comprises 

selecting a proxy cache from the candidate set of proxies based at least on discounted 
response time that prefers the anchor proxy cache unless the response time is better by a 
predetermined amount. 

7. The method according to Claim 1, wherein said selecting step comprises 
15 selecting a proxy cache from the candidate set of proxies based at least on the condition 
that a proxy cache server is not overloaded. 
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8. The method according to Claim 3, wherein the nearby partitions comprise 
partitions with hash values greater than that of the anchor partition. 

9. The method according to Claim 3, wherein the nearby partitions comprise 
partitions with hash values less than that of the anchor partition. 

5 10. The method according to Claim 3, wherein the nearby partitions comprise 

partitions with hash values both greater and less than that of the anchor partition. 

1 1 . The method according to Claim 3, wherein said mapping step comprises 
hashing each hash partition into a number between 1 and P, wherein P represents the total 
number of proxies. 

10 12. The method according to Claim 3, wherein said mapping step further 

comprises: 

for each proxy, generating N/P random numbers between 0 and 1, wherein N 
represents the total number of hash partitions and P represents the total number of 
proxies; 

15 generating a proxy list by sorting the corresponding N random numbers generated; 

and 
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assigning each hash partition to one proxy based on the sorted proxy list. 

13. The method according to Claim 4, wherein the step of creating an indirect 
mapping of hash partitions to a proxy ID array further comprises: 

forming a proxy ID array with collaborative proxy caches; 

5 creating a hash partition segment that maps each hash partition to the index of the 

proxy ID array; and 

replicating the hash partition segment for a predetermined number of times. 

14. System for selecting a proxy cache, said system comprising: 

an identifier for identifying a candidate set of proxy caches for a given URL based 
10 on information related to said URL; and 

a selector for selecting a proxy cache from the candidate set at least on the basis of 

latency. 

15. The system according to Claim 14, wherein said selector is adapted to select a 
proxy cache from the candidate set at least on the basis of latency and load condition. 

15 16. The system according to Claim 14, wherein said identifier is adapted to: 
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hash the URL into an anchor hash partition; 

form a candidate set of hash partitions by including one or more nearby partitions 
into said anchor hash partition; and 

map each partition to a proxy cache. 

17. The system according to Claim 14, wherein said identifier is adapted to: 
create an indirect mapping of hash partitions to a proxy ID array; 

hash the URL into an anchor hash partition; 
find the corresponding anchor proxy cache; and 

form a candidate set of proxy caches by including one or more nearby proxy 
caches from the proxy ID array into the anchor proxy cache. 

18. The system according to Claim 14, wherein said selector is adapted to select a 
proxy cache from the candidate set of proxies based at least on minimum response time, 

19. The system according to Claim 14, wherein said selector is adapted to select a 
proxy cache from the candidate set of proxies based at least on discounted response time 
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that prefers the anchor proxy cache unless the response time is better by a predetermined 
amount. 

20. The system according to Claim 14, wherein said selector is adapted to select a 
proxy cache from the candidate set of proxies based at least on the condition that a proxy 

5 cache server is not overloaded. 

21 . The system according to Claim 16, wherein the nearby partitions comprise 
partitions with hash values greater than that of the anchor partition. 

22. The system according to Claim 16, wherein the nearby partitions comprise 
partitions with hash values less than that of the anchor partition. 

10 23. The system according to Claim 16, wherein the nearby partitions comprise 

partitions with hash values both greater and less than that of the anchor partition. 

24. The system according to Claim 16, wherein said identifier is adapted to map 
each hash partition into a number between 1 and P, wherein P represents the total number 
of proxies. 

15 25. The system according to Claim 16, wherein said identifier, in mapping, is 

adapted to: 



YO-999-594 



-26- 



for each proxy, generate N/P random numbers between 0 and 1, wherein N 
represents the total number of hash partitions and P represents the total number of 
proxies; 

generate a proxy list by sorting the corresponding TV random numbers generated; 

5 and 

assign each hash partition to one proxy based on the sorted proxy list. 

26. The system according to Claim 17, wherein said identifier, in creating an 
indirect mapping, of hash partitions to a proxy ID array, is adapted to: 

form a proxy ID array with collaborative proxy caches; 

10 create a hash partition segment that maps each hash partition to the index of the 

proxy ID array; and 

replicate the hash partition segment for a predetermined number of times. 

27. A program storage device readable by machine, tangibly embodying a 
program of instructions executable by the machine to perform method steps for selecting a 

15 proxy cache, said method steps comprising: 
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identifying a candidate set of proxy caches for a given URL based on information 
related to said URL; and 

selecting a proxy cache from the candidate set at least on the basis of latency. 
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ARRANGEMENTS AND METHODS FOR LATENCY-SENSITIVE 

HASHING FOR COLLABORATIVE WEB CACHING 

Abstract of the Disclosure 

Systems and methods for collaborative web caching among geographically 
5 distributed cache servers, particularly, latency- sensitive hashing systems and methods for 
collaborative web caching among geographically distributed proxy caches. Network 
latency delays as well as proxy load conditions are taking into consideration during 
hashing. As a result, requests can be hashed into geographically closer proxy caches if 
the load conditions permit. Otherwise, requests will be hashed into geographically distant 
10 proxy caches to better balance the load among the caches. 



YO-999-594 



-29- 



1/9 
Wu et al. 
Y0-999-594 (DMS) 



00 

o 



o 




CO 

5 vJSt 



■= <D © 

e § i 

% z CO 



o 
o 



CD 

c 

CD 

4-" 

CD 



CD 



CD 



g en 



o5 § 



CD 
O 



CM 



0 

75 



"o 



in 



CD 



O O 



cd cd 



o o c 

)r CO CD 



E 

£5 
E 

+- » 

to 

CO 



LL 



2/9 
Wu et al. 
Y0-999-594 (DMS) 




4/9 
Wu et al. 
Y0-999-594 (DMS) 




5/9 
Wu et al. 
Y0-999-594 (DMS) 



map the hash value into an 
anchor hash partition 



form a candidate set of hash 
partitions including the anchor 
partition 



map candidate partitions into 
candidate proxy caches 



6/9 
Wu et al. 
Y0-999-594 (DMS) 



create a proxy ID array with a 
two-level round-robin approach 


1 


f 



create a hash partition segment 
and assign the indices of the proxy 
ID array to the hash partitions 



replicate the hash partition 
segment for a number of times 



9/9 
Wu et al. 
Y0-999-594 (DMS) 




DECLARATION AND POWER OF ATTORNEY FOR PATENT APPLICATION 



As a below named inventor, I hereby declare that: 

My residence, post office address and citizenship are as stated below next to my name; 

I believe I am the original, first and sole inventor (if only one name is listed below) or an original, first 
and joint inventor (if plural names are listed below) of the subject matter which is claimed and for which a 
patent is sought on the invention entitled: 

ARRANGEMENTS AND METHODS FOR LATENCY -SENSITIVE HASHING FOR COLLABORATIVE WEB CACHING 

the specification of which (check one) 
X i3 attached hereto. 

was filed on as International Business Machines Docket No. Y0999-594 

ket PCT International Application Number 

and was amended on _ (if applicable) 

I hereby state that I have reviewed and understand the contents of the above identified 
specification, including the claims, as amended by any amendment referred to above. 

- I acknowledge the duty to disclose information which is material to the patentability of 
• this application in accordance with Title 37, Code of Federal Regulations, Section 1.56. 

1 I hereby claim foreign priority benefits under Title 35, United States Code, §119 (a) -(d) 
^ or §365 (b) of any foreign application (s) for patent or inventor's certificate, or §365 (a) 
I of any PCT International application which designated at least one country other than the 
I United States, listed below and have also identified below, by checking the box, any 
I foreign application for patent or inventor's certificate, or PCT International 
I application, having a filing date before that of the application on which priority is 
claimed: 

Priority Claimed 
Yes No 



e. Prior Foreign Application (a) 


1 (Number) 


(Country) 


(Day/Month/Year Filed) 


i (Number) 


(Country) 


(Day/Month/ Year Piled) 


(Number) 


(Country) 


{Day/Month/Year Piled) 



Yes No 



Yes No 



I hereby claim the benefit under 35 U.S.C. 8119(e) of any United States provisional application (s) listed below. 



(Application Number) (Filing Date) 



(Application Number) (Filing Date) 



Page 1 of 3 



DELARATION AND POWER OF ATTORNEY FOR PATENT APPLICATION 

I hereby claim the benefit under 35 U.S.C. §120 of any United States Application (s) , or 
§365 (c) of any PCT International application designating the United States, listed below 
and, insofar as the subject matter of each of the claims of this application is not 
disclosed in the prior United States, or PCT International application in the manner 
provided by the first paragraph of 35 U.S.C. §112, I acknowledge the duty to disclose 
information material to the patentability of this application as defined in 37 CFR §1.56 
which occurred between the filing date of the prior application and the national or PCT 
international filing date of this application: 



(Application Serial No.) (Filing Date) (Status) (patented, pending, abandoned) 



(Application Serial No.) (Filing Date) (Status) (patented, pending, abandoned) 

I hereby declare that all statements made herein of my own knowledge are true and that all 
statements made on information and belief are believed to be true; and further that these 
statements were made with the knowledge that willful false statements and the like so made 
are punishable by fine or imprisonment, or both, under Section 1001 of Title 18 of the 
United States Code and that willful false statements may jeopardize the validity of the 
; application or any patent issued thereon. 

! POWER OF ATTORNEY: As a named inventor I hereby appoint the following attorney (s) and/or 
; agent (s) to prosecute this application and transact all business in the Patent and 
! Trademark Office connected therewith (list name and registration number) . 

! Manny W. Schecter (Reg. 31,722), Terry J. Ilardi (Reg. 29,936), Christopher A. Hughes 
i (Reg. 26,914), Edward A. Pennington (Reg. 32,588), John E. Hoel (Reg. 26,279), Joseph C. 

Redmond, Jr. (Reg. 18,753), Douglas W. Cameron (Reg. 31,596), Stephen C. Kaufman (Reg. 

29,551), Jay P. Sbrollini (Reg. 36,266), Wayne L. Ellenbogen (Reg. No. 43,602), Robert M. 

Trepp (Reg. 25,933), Louis P. Herzberg (Reg. 41,500), Louis J. Percello (Reg. 33,206), 

Paul J. Otterstedt (Reg. 37,411), Daniel P. Morris (Reg. 32,053), and David M. Shofi (Reg. 
I 39,835) 

! Send Correspondence to: FERENCE & ASSOCIATES, 129 Oakhurst Road, Pittsburgh, PA 15215 m 



Direct Telephone Calls to: (name and telephone number) Stanley D. Ference III, (41 2) 781-7386 



Kun-Lung Wu 

Full name of sole or f irst^inventor 





1/ / 7-0 <>& 

C Date / 



Inventor 1 s Signature 
357 Columbine jgourt, Yorktown Heights, NY 10598 



Residence 
Taiwan 



Citizenship 
Same as above 



Post Office Address 



Page 2 of 3 



DELARATION AND POWER OF ATTORNEY FOR PATENT APPLICATION 



Philip Shi -lung Yu 

Full name of second joint -inventor, if any 




Date 



18 S t or noway e, Chappaqua, NY 10514 
Residence 



USA 

Citizenship 

Same as above 

Post Office Address 



Page 3 of 3 



